package com.yx.shiro;

import org.apache.shiro.authc.AuthenticationException;
import org.apache.shiro.authc.AuthenticationInfo;
import org.apache.shiro.authc.AuthenticationToken;
import org.apache.shiro.authc.SimpleAuthenticationInfo;
import org.apache.shiro.realm.AuthenticatingRealm;
import org.apache.shiro.util.ByteSource;

public class MyRealm extends AuthenticatingRealm {

    // 自定义登录认证方法,shiro的login方法底层会调用该类的认证方法进行认证
    // 需要配置自定义的realm生效,在ini文件种配置，或者在springboot中进行配置
    // 该方法只是获取进行对比的信息,认证逻辑还是按照shiro底层认证完成



    @Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {
        // 1、获取身份信息
        String principal = authenticationToken.getPrincipal().toString();
        // 2、获取凭证信息
        String password = new String((char[]) authenticationToken.getCredentials());
        System.out.println("认证用户信息："+principal+"----"+password);
        // 3、获取数据库存储的用户信息
        if (principal.equals("admin")) {
            //  3.1 从数据库中存储的加盐3次迭代的密码
            String pwdInfo = "02efd36573febd6863e09ff49bd59c59";
// 4、创建封装校验逻辑的对象,封装数据返回
            AuthenticationInfo info = new SimpleAuthenticationInfo(
                    authenticationToken.getPrincipal(),
                    pwdInfo,
                    ByteSource.Util.bytes("2681196279"),
                    authenticationToken.getPrincipal().toString()
            );
            return info;
        }

        return null;
    }
}
